home *** CD-ROM | disk | FTP | other *** search
/ Workbench Add-On / Workbench Add-On - Volume 1.iso / BBS-Archive / Comm / AmiTCP30b2.lha / netinclude / netinet / ip_icmp.h < prev    next >
C/C++ Source or Header  |  1993-08-01  |  6KB  |  156 lines

  1. /*
  2.  * $Id: ip_icmp.h,v 1.2 1993/03/03 21:37:00 jraja Exp $
  3.  *
  4.  * HISTORY
  5.  * $Log: ip_icmp.h,v $
  6.  * Revision 1.2  1993/03/03  21:37:00  jraja
  7.  * Added #ifdef to prevent multiple inclusion.
  8.  *
  9.  * Revision 1.2  1993/03/03  21:37:00  jraja
  10.  * Added #ifdef to prevent multiple inclusion.
  11.  *
  12.  * Revision 1.1  92/11/17  16:29:37  16:29:37  jraja (Jarno Tapio Rajahalme)
  13.  * Initial revision
  14.  * 
  15.  *
  16.  */
  17.  
  18. /*
  19.  * Copyright (c) 1982, 1986 Regents of the University of California.
  20.  * All rights reserved.
  21.  *
  22.  * Redistribution and use in source and binary forms, with or without
  23.  * modification, are permitted provided that the following conditions
  24.  * are met:
  25.  * 1. Redistributions of source code must retain the above copyright
  26.  *    notice, this list of conditions and the following disclaimer.
  27.  * 2. Redistributions in binary form must reproduce the above copyright
  28.  *    notice, this list of conditions and the following disclaimer in the
  29.  *    documentation and/or other materials provided with the distribution.
  30.  * 3. All advertising materials mentioning features or use of this software
  31.  *    must display the following acknowledgement:
  32.  *    This product includes software developed by the University of
  33.  *    California, Berkeley and its contributors.
  34.  * 4. Neither the name of the University nor the names of its contributors
  35.  *    may be used to endorse or promote products derived from this software
  36.  *    without specific prior written permission.
  37.  *
  38.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  39.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  40.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  41.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  42.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  43.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  44.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  45.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  46.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  47.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  48.  * SUCH DAMAGE.
  49.  *
  50.  *    @(#)ip_icmp.h    7.5 (Berkeley) 6/28/90
  51.  */
  52.  
  53. #ifndef IP_ICMP_H
  54. #define IP_ICMP_H
  55.  
  56. /*
  57.  * Interface Control Message Protocol Definitions.
  58.  * Per RFC 792, September 1981.
  59.  */
  60.  
  61. /*
  62.  * Structure of an icmp header.
  63.  */
  64. struct icmp {
  65.     u_char    icmp_type;        /* type of message, see below */
  66.     u_char    icmp_code;        /* type sub code */
  67.     u_short    icmp_cksum;        /* ones complement cksum of struct */
  68.     union {
  69.         u_char ih_pptr;            /* ICMP_PARAMPROB */
  70.         struct in_addr ih_gwaddr;    /* ICMP_REDIRECT */
  71.         struct ih_idseq {
  72.             n_short    icd_id;
  73.             n_short    icd_seq;
  74.         } ih_idseq;
  75.         int ih_void;
  76.     } icmp_hun;
  77. #define    icmp_pptr    icmp_hun.ih_pptr
  78. #define    icmp_gwaddr    icmp_hun.ih_gwaddr
  79. #define    icmp_id        icmp_hun.ih_idseq.icd_id
  80. #define    icmp_seq    icmp_hun.ih_idseq.icd_seq
  81. #define    icmp_void    icmp_hun.ih_void
  82.     union {
  83.         struct id_ts {
  84.             n_time its_otime;
  85.             n_time its_rtime;
  86.             n_time its_ttime;
  87.         } id_ts;
  88.         struct id_ip  {
  89.             struct ip idi_ip;
  90.             /* options and then 64 bits of data */
  91.         } id_ip;
  92.         u_long    id_mask;
  93.         char    id_data[1];
  94.     } icmp_dun;
  95. #define    icmp_otime    icmp_dun.id_ts.its_otime
  96. #define    icmp_rtime    icmp_dun.id_ts.its_rtime
  97. #define    icmp_ttime    icmp_dun.id_ts.its_ttime
  98. #define    icmp_ip        icmp_dun.id_ip.idi_ip
  99. #define    icmp_mask    icmp_dun.id_mask
  100. #define    icmp_data    icmp_dun.id_data
  101. };
  102.  
  103. /*
  104.  * Lower bounds on packet lengths for various types.
  105.  * For the error advice packets must first insure that the
  106.  * packet is large enought to contain the returned ip header.
  107.  * Only then can we do the check to see if 64 bits of packet
  108.  * data have been returned, since we need to check the returned
  109.  * ip header length.
  110.  */
  111. #define    ICMP_MINLEN    8                /* abs minimum */
  112. #define    ICMP_TSLEN    (8 + 3 * sizeof (n_time))    /* timestamp */
  113. #define    ICMP_MASKLEN    12                /* address mask */
  114. #define    ICMP_ADVLENMIN    (8 + sizeof (struct ip) + 8)    /* min */
  115. #define    ICMP_ADVLEN(p)    (8 + ((p)->icmp_ip.ip_hl << 2) + 8)
  116.     /* N.B.: must separately check that ip_hl >= 5 */
  117.  
  118. /*
  119.  * Definition of type and code field values.
  120.  */
  121. #define    ICMP_ECHOREPLY        0        /* echo reply */
  122. #define    ICMP_UNREACH        3        /* dest unreachable, codes: */
  123. #define        ICMP_UNREACH_NET    0        /* bad net */
  124. #define        ICMP_UNREACH_HOST    1        /* bad host */
  125. #define        ICMP_UNREACH_PROTOCOL    2        /* bad protocol */
  126. #define        ICMP_UNREACH_PORT    3        /* bad port */
  127. #define        ICMP_UNREACH_NEEDFRAG    4        /* IP_DF caused drop */
  128. #define        ICMP_UNREACH_SRCFAIL    5        /* src route failed */
  129. #define    ICMP_SOURCEQUENCH    4        /* packet lost, slow down */
  130. #define    ICMP_REDIRECT        5        /* shorter route, codes: */
  131. #define        ICMP_REDIRECT_NET    0        /* for network */
  132. #define        ICMP_REDIRECT_HOST    1        /* for host */
  133. #define        ICMP_REDIRECT_TOSNET    2        /* for tos and net */
  134. #define        ICMP_REDIRECT_TOSHOST    3        /* for tos and host */
  135. #define    ICMP_ECHO        8        /* echo service */
  136. #define    ICMP_TIMXCEED        11        /* time exceeded, code: */
  137. #define        ICMP_TIMXCEED_INTRANS    0        /* ttl==0 in transit */
  138. #define        ICMP_TIMXCEED_REASS    1        /* ttl==0 in reass */
  139. #define    ICMP_PARAMPROB        12        /* ip header bad */
  140. #define    ICMP_TSTAMP        13        /* timestamp request */
  141. #define    ICMP_TSTAMPREPLY    14        /* timestamp reply */
  142. #define    ICMP_IREQ        15        /* information request */
  143. #define    ICMP_IREQREPLY        16        /* information reply */
  144. #define    ICMP_MASKREQ        17        /* address mask request */
  145. #define    ICMP_MASKREPLY        18        /* address mask reply */
  146.  
  147. #define    ICMP_MAXTYPE        18
  148.  
  149. #define    ICMP_INFOTYPE(type) \
  150.     ((type) == ICMP_ECHOREPLY || (type) == ICMP_ECHO || \
  151.     (type) == ICMP_TSTAMP || (type) == ICMP_TSTAMPREPLY || \
  152.     (type) == ICMP_IREQ || (type) == ICMP_IREQREPLY || \
  153.     (type) == ICMP_MASKREQ || (type) == ICMP_MASKREPLY)
  154.  
  155. #endif /* !IP_ICMP_H */
  156.